## FOSS FPGA

Martin Hubáček

@hubmartin 
martinhubacek.cz
youtube.com/hubmartin

# Q = I0 & I1 & I2 & I3



## Combinatorial logic



| 10 - 13 | Q |
|---------|---|
| 0000    | 0 |
| 0001    | 0 |
| 0010    | 0 |
| 0011    | 0 |
| 0100    | 0 |
| 0101    | 0 |
| 0110    | 0 |
| 0111    | 0 |
| 1000    | 0 |
| 1001    | 0 |
| 1010    | 0 |
| 1011    | 0 |
| 1100    | 0 |
| 1101    | 0 |
| 1110    | 0 |
| 1111    | 1 |

```
Q = I0 & I1 & I2 & I3

if(Q != Q_previous)
{ ... }
```

Q previous = Q

## Sequential logic



Register

Memory

Counter

## **FPGA** fabric

IO, BRAM, PLL, DSP

Hard-core/Soft-core peripherals or CPUs



## Official tools

Xilinx Vivado (ISE WebPACK)

Intel Quartus (Altera)

Lattice Diamond









## Official tools negatives

Complex many gigabyte tools

License installations

Non-effective IPs

Highest FPGA lines needs licenses



## Generic low-cost FPGA boards

Altera MAX2 + JTAG \$10

Altera Cyclone II + \$15



Lattice IceStick \$25



Lattice MachXO2 (FLASH) \$30



Cyclone III / IV / V



Intel (Altera) CYC1000 / MAX \$40

## How to reverse engineer an FPGA?

No details of programming internal logic and bitstream

Compare small gradual code changes (change > synthesize > compare bitstream)

Fuzzing

#### Project IceStorm – iCE40 HX1K Overview

Project IceStorm aims at documenting the bitstream format of Lattice iCE40 FPGAs and providing simple to

LOGIC LOGIC LOGIC RAMT LOGIC

(88) (98)

RAMT LOGIC

RAMB LOGIC

RAMT LOGIC

(10.0)(11 0)

(11 2) (12 2)

(12 1)

RAMB LOGIC LOGIC

(111)

|                    | is auto-generated by icebox |                  |
|--------------------|-----------------------------|------------------|
| A machine-readable | form of the database can be | downloaded here. |

RAMT LOGIC LOGIC

(22) (32)

(21) (31)

(10)

LOGIC RAMB LOGIC LOGIC

(3.0) (40)

(013) (113) (213) (313) (413) (513) (613) (713) (813) (913) (1013) (1113)

(0.11) (1.11) (2.11) (3.11) (4.11) (5.11) (6.11) (7.11) (8.11) (9.11) (10.11) (11.11) LOGIC LOGIC RAMT LOGIC LOGIC LOGIC LOGIC LOGIC RAMT LOGIC LOG (1 10) (2 10) (3 10) (4 10) (5 10) (6 10) (7 10) (8 10) (9 10) (10 10) (11 10) (12 1 | LOGIC | RAMB | LOGIC | RAMB | LOGIC | LOGIC | LOGIC | (109) | (119) | (129) |

> (68) (78)

RAMT LOGIC LOGIC LOGIC LOGIC LOGIC

(6.3)

(62)

(60)

LOGIC LOGIC

(7.6) (86)

(7.5) (8.5) LOGIC RAMT LOGIC LOGIC LOGIC LOGIC LOGIC RAMT LOGIC LOGIC (34) (44) (54) (64) (74) (84) (94) LOGIC RAMB LOGIC LOGIC LOGIC LOGIC LOGIC LOGIC

(83)

(8.2)

LOGIC LOGIC

(81) (91) (10 I)

(8.0) (9.0)

(17) (27) (37) (47) (57) (67) (77) (87) (97)

(46) (56) (66)

(45) (55) (65)

(51)

(5.0)

Click on a highlighted tile below to view the bitstream details for the tile. The highlighted tiles (617)

#### Project IceStorm – iCE40 HX1K LOGIC Tile (79)

The iCE40 FPGA fabric is organized into tiles. The configuration bits themself have the same if Project JeeStorm aims at documenting the bitstream format of Lattice iCE40 FPGAs and providing simple tools for analyzing and creating bitstream files. This is work in progress.

This page describes the LOGIC Tile (79), what nets and configuration bits it has and how it is connected to its neighbourhood.

|   | 10<br>(1 17)    | 10<br>(2 17)    | 10<br>(3 17)   | 10<br>(4 17)   | 10<br>(5 17)    | 10<br>(6 17)    | 10<br>(7 17)    | 1O<br>(8 17)    | IO<br>(9 17)    | 10<br>(10 17)   | 10<br>(11 17)    | 10<br>(12 17)    | LOGIC Tile           | LOGIC Tile           | LOGIC Tile<br>(7 11) | LOGIC Tile<br>(8 11) | LOGIC Tile<br>(9 11) |            |
|---|-----------------|-----------------|----------------|----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|------------------|------------------|----------------------|----------------------|----------------------|----------------------|----------------------|------------|
|   | LOGIC<br>(1 16) | LOGIC<br>(2 16) | RAMT<br>(3 16) | LOGIC<br>(416) | LOGIC<br>(5 16) | LOGIC<br>(6·16) | LOGIC<br>(7 16) | LOGIC<br>(8 16) | LOGIC<br>(9 16) | RAMT<br>(10 16) | LOGIC<br>(11 16) | LOGIC<br>(12 16) | (5 11)               | (6 11)               |                      |                      |                      |            |
|   | LOGIC<br>(1 15) | LOGIC<br>(2 15) | RAMB<br>(3 15) | LOGIC<br>(415) | LOGIC<br>(5 15) | LOGIC<br>(6 15) | LOGIC<br>(7 15) | LOGIC<br>(8 15) | LOGIC<br>(9 15) | RAMB<br>(10 15) | LOGIC<br>(11 15) | LOGIC<br>(12 15) | LOGIC Tile<br>(5 10) | LOGIC Tile<br>(6 10) | LOGIC Tile<br>(7 10) | LOGIC Tile<br>(8 10) | LOGIC Tile<br>(9 10) |            |
|   | LOGIC<br>(1 14) | LOGIC<br>(2 14) | RAMT<br>(3 14) | LOGIC<br>(414) | LOGIC<br>(5 14) | LOGIC<br>(614)  | LOGIC<br>(7 14) | LOGIC<br>(8 14) | LOGIC<br>(9 14) | RAMT<br>(10 14) | LOGIC<br>(11 14) | LOGIC<br>(12 14) | LOGIC Tile           | LOGIC Tile |
|   | LOGIC<br>(113)  | LOGIC<br>(2 13) | RAMB<br>(3 13) | LOGIC<br>(413) | LOGIC<br>(5 13) | LOGIC<br>(6 13) | LOGIC<br>(7 13) | LOGIC<br>(8 13) | LOGIC<br>(913)  | RAMB<br>(10 13) | LOGIC<br>(11 13) | LOGIC<br>(12 13) | (5 9)                |                      | (7 9)                | (8 9)                | (99)                 |            |
|   | LOGIC<br>(1 12) | LOGIC<br>(2 12) | RAMT<br>(3 12) | LOGIC<br>(412) | LOGIC<br>(5 12) | LOGIC<br>(612)  | LOGIC<br>(7 12) | LOGIC<br>(8 12) | LOGIC<br>(9 12) | RAMT<br>(10 12) | LOGIC<br>(11 12) | LOGIC<br>(12 12) | LOGIC Tile<br>(5 8)  |                      | LOGIC Tile           | LOGIC Tile           | LOGIC Tile           | LOGIC Tile |
|   | LOGIC<br>(111)  | LOGIC<br>(2 II) | RAMB<br>(3 11) | LOGIC<br>(411) | LOGIC<br>(5 11) | LOGIC<br>(6 11) | LOGIC<br>(711)  | LOGIC<br>(8 11) | LOGIC<br>(911)  | RAMB<br>(10 11) | LOGIC<br>(11 11) | LOGIC<br>(12 11) |                      |                      | (0.0)                | (7.0)                | (0.0)                | (3.0)      |
|   | LOGIC<br>(1 10) | LOGIC<br>(2 10) | RAMT<br>(3 10) | LOGIC<br>(410) | LOGIC<br>(5 10) | LOGIC<br>(6 10) | LOGIC<br>(710)  | LOGIC<br>(8 10) | LOGIC<br>(9 10) | RAMT<br>(10 10) | LOGIC<br>(11 10) | LOGIC<br>(12 10) | LOGIC Tile<br>(5 7)  | LOGIC Tile<br>(67)   | LOGIC Tile<br>(7 7)  | LOGIC Tile<br>(8 7)  | LOGIC Tile<br>(9 7)  |            |
| Ī | Locic           | Locac           | DAME           | Locac          | Locac           | Locic           | Locic           | Logic           | Locic           | DAME            | Locac            | Locac            |                      |                      |                      |                      |                      |            |

#### Configuration Bitmap

A LOGIC Tile has 864 config bits in 16 groups of 54 bits each: B0[53:0], B1[53:0], B2[53:0], B3[53:0], B4[53:0], B5[53:0], B6[53:0], B7[53:0], B8[53:0], B9[53:0], B10[53:0], B11[53:0], B12[53:0], B13[53:0], B14[53:0], B15[53:0] BII B12 B13 B14

10 (7.0)

## FOSS FPGA chips/boards

IceStorm - iCE40 (ICE40, 8k, 128kb, PLL)

- TinyFPGA BX \$38
- <u>iCEBreaker</u>
- Glasgow
- Olimex iCE40HX8K-EVB
- ICOboard (Rpi HAT) <u>OpenTechLab YouTube</u>
- Alhambra (Arduino footprint)

#### Trellis - ECP5

(85k, 3.7Mb BRAM, 156 18x18 DSPs, 5Gbps SERDES)

- TinyFPGA EX
- ULX3S

X-Ray - Xilinx 7-series







## **Icestudio**



## **APIO**

Makefile / ATOM

Dropbox/ws2812b\_apio

Litex, Vivado non efficient <a href="https://www.bunniestudios.com/blog/?p=5018">https://www.bunniestudios.com/blog/?p=5018</a>

https://www.youtube.com/watch?v=v7WrTmexod0 Tim has too many projects

https://fupy.github.io upython on litex fpga

Verilog compiled simulator - Verilator <a href="https://www.veripool.org/projects/verilator/wiki/Documentation">https://www.veripool.org/projects/verilator/wiki/Documentation</a>

Přednáška ORconf19 https://ds0.me/orconf19.pdf

## Simulace

iverilog

Gtkview

Verilator

https://www.edaplayground.com/

## **PicoSOC**

Soft-core RISC-V

Compilation is faster than synthetis



## Two PicoSOCs place&route



https://twitter.com/q3k/status/1024623710165237760

## Migen, Litex

Migen, nMigen - python nástroj pro generování komplexního hardware

Nekompiluje python, pomáhá tvořit HDL kód

LiteX - LiteX is a MiSoC-based SoC builder using Migen as Python DSL that can be used to create SoCs and full FPGA designs.





HDMI2USB.tv



## **Future**

Partial reconfiguration

Glasgow

. . .



# **AT&T**HACKATHON 22,-23,11, 2019

Registrace zdarma \$7000 Prize money 22.-23.listopad Brněnské výstaviště E

https://www.hackathons.cz/

#### **TECHNOLOGIES FOR THE FUTURE**

- Smart Village
- Smart Factory
- Smart Office
- · Device, Grid & Infrastructure security

**24 hour marathon** for developers, coders, geeks and enthusiasts who have great ideas, want to broaden them and bring innovative solutions.

PRIZE MONEY: USD 4,000 | USD 2,000 | USD 1,000



**AT&T**HACKATHON
22.-23.11.2019









Hardware Development Podcast se zaměřuje na zajímavá témata z oblasti vývoje, výroby a oživování elektroniky.

https://soundcloud.com/hwdevpodcast

### Top played tracks

| 1 |       | #1 Vývoj hardware není nákup rohlíku | 1,763 |
|---|-------|--------------------------------------|-------|
| 2 |       | #6 loT sítě Sigfox, LoRa a NB-loT    | 1,576 |
| 3 |       | #3 Žádné kecy, dnes pájíme v peci!   | 960   |
| 4 |       | #2 Bez měření není vědění            | 952   |
| 5 |       | #4 Low Power                         | 799   |
| 6 | ( ) S | #9 Digitrony                         | 781   |
| 7 |       | #7 RTOSy, plánovače, tasky           | 779   |
| 8 |       | #8 Elektronická odysea               | 700   |
| 9 |       | #5 Distribuce křemíku                | 697   |





#### **HWDEV Podcast**

Hardware Development Podcast se zaměřuje na zajímavá témata z oblasti vývoje, výroby a oživování elektroniky.

https://soundcloud.com/hwdevpodcast



@hubmartin



martinhubacek.cz

www.youtube.com/hubmartin

